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(54) Secure data processing method and system 

(57) A secure data processing system comprises a 
central processor unit (11), memory (12) and a security 
circuit (1 5) in the form of an application specific integrat- 
ed circuit. The security circuit has a cryptographic en- 
gine (1 9) and a cryptographic i<ey store (18). 

The cryptographic engine operates on the contents 
of the cryptographic l^ey store to generate a digital sig- 
nature. Means are provided to generate a digital signa- 



ture from a software or hardware component to be 
checked for authenticity and to compare the digital sig- 
nature from the component with the generated digital 
signature. An indication of the authenticity of the com- 
ponent is generated as a result of the comparison. The 
components of the system that can be checked include 
the tool firmware (16) for the system, the operating sys- 
tem and piug-in cards (13) for the system. 
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Description 

The present invention concerns a secure data processing method and system and is of particular application to a 
financial terminal. 

5 In a data processing system it is usual to provide a programmable central processor unit, memory and other 

software and hardware components. It is desirable to provide a software and hardware environment where the user 
or operator of the system can trust ail of the software and hardware components of the system. To achieve this objective 
some means has to be provided to decide whether the components of the system have been compromised either at 
initial instal lation of the components or at a later stage when new or upgraded components are introduced to the system. 

10 For a data processing system including a programmable central processor unit It is important to authenticate the 
operating system of the central processor unit. If plug-in cards are used to provide upgrades to the functionality of the 
system it is also important to authenticate these plug-in cards. The means to authenticate the components of the data 
processing system must be such as to provide security for the authentication process itself if the authentication process 
is to be reliable in detecting any compromise of the components of the system. 

IS It is therefore an object of the present invention to provide an effective method and system for testing one or more 
components of a data processing system in order to determine the authenticity of the tested component or components. 

According to the present invention there is provided a method of determining the authenticity of one or more system 
components of a data processing system which also includes a programmable central processor unit, memory, a se- 
curity circuit having a cryptographic engine, and a cryptographic key store, the method comprising the steps of entering 

20 one or more keys into the cryptographic key store, operating on the contents of the cryptographic key store by means 
of the cryptographic engine to generate a digital signature referenced to a component of the system to be authenticated, 
generating a digital signature from the component to be authenticated, and providing an indicatton of authenticity by 
comparing the digital signature generated by the cryptographic engine with that generated from the component to be 
authenticated. 

2S Further according to the present invention there is provided a data processing system including one or more com- 
ponents to be checked for authenticity, a programmable central processing unit, memory and a security circuit having 
a cryptographic engine and a cryptographic key store for storing one or more cryptographic keys, the cryptographic 
engine being adapted to operate on the contents of the cryptographic key store to generate a digital signature refer- 
enced to a component of the system to be checked for authenticity, and means being provided to generate a digital 

30 signature from the component to be checked for authenticity and to provide an indication of authenticity by comparing 
the digital signature generated by the cryptographic engine with that generated from the component to be authentk:ated. 
The invention will now be described, by way of example, with reference to the accompanying drawings in which: 

Figure 1 shows a block diagram of a data processing system according to the present inventbn. 

$5 

Figure 2 shows detail of a security circuit included in the system of Figure 1. 
Figure 3 shows a flow diagram of the operation of the system of Figures 1 and 2. and 
40 Figure 4 shows a flow diagram relating to the update of cryptographic keys used in the system of Figures 1 and 2. 

Referring first to Figure 1, there is shown a data processing system 10 which may be an automatic teller system 
or a personal computer system. The system 10 has a central processor unit 11 . a memory 12. provision for additional 
plug-in cards 13. permanent storage 14. a security circuit 15 in the form of an applk:atbn specific integrated circuit 
45 (ASIC) and booX firmware 16. The components of the data processing system 10 are linked by means of a processor 
data bus 17 In conventional manner well understood by those skilled in the art. In addition the system runs under an 
operating system (OS) in a manner well understood in the art. 

The isecurity circuit 15 is shown in greater detail in Figure 2. Referring now to Figure 2. the circuit 15 includes a 
cryptographic key and password store 18. a cryptographic engine 19, a store 20 for a digital signature, control and 
so interface firmware 21 and an I/O bus 22 communicating with the system bus 17. The cryptographic engine 1 9 supports 
both symmetric and asymmetric algorithms. The control and interfacing firmware 21 is designed to perform the initial 
start-up of the data processing system. 

Means (not shown) are provided to allow the operator of the system to input keys and passwords into the security 
circuit 15. All the keys stored in the storage 18 are password protected, with the password defined (and changeable) 
ss by input from the user of the system. A key can therefore only be altered if the corresponding password is known and 
entered by the user. 

The keys in the store 18 are present to allow system components including firmware components and software 
components to be authenticated. The components to be authenticated in the system of Figure 1 include the operating 
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system (OS), Ihe firmware on the plug-in cards 1 3, and the boot firmware 16. The invention may be applied to a system 
which has either more or fewer system components to be authenticated than the system depicted in Figure 1. For 
example a simpler system may not provide for the plug-in cards 13 and in this case provision may not be required to 
authenticate such cards. 

5 Each of the components of the system which are to be authenticated includes a digital signature which is embedded 

in the firmware of the component. The digital signature is embedded at a predefined location and is created by the 
supplier of the component as part of the manufacturing process. The algorithm for generating the digital signature uses 
an asynrrmetric key pair, with the vendor supplier keeping the private key securely and distributing the public key with 
the component to be authenticated. The public key is entered into the circuit 15 when the component is installed into 

10 the data processing system 10, 

The creator of each of the cryptographic keys entered into the circuit 1 5 will depend on the source of the component 
to which the keys relate. The keys may be symmetric or asymmetric and validate the respective components of the 
system according to the cryptographic process determined within the security circuit 15. The authenticatbn process 
is tamper proof by reason of the fact that the process is contained within the security ASIC 15 and it is not feasible to 

IS alter the contents of this ASIC. The security system can not be disabled. 
A number of keys are pre-defined as shown in the foltowing Table 1 : 



TABLE 1 
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Key Name 
Boot 



Type 

Asymmetric 



Use 

Creator 
Validation of 
boot firmware 
by ASIC 15 
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3S 



40 



Cards (1-x) 



OS 



Asymmetric 



Symmetric 



ASIC 
The creator 
of boot 
firmware 
Validation of 
firmware of 
cards (1-x) 
cards (1-x) 
Validation of 
operating 
system boot 
Automatically 
generated by 
the ASIC (15) 



The creator 
of the card 
firmware for 



The process of starting up the data processing system of Figures 1 and 2 is shown in the flow diagram of Figure 
3. Referring now to Figure 3, the power on step 23 Is followed by processor start-up step 24 and the execution at step 

4S 25 of the initial code of the ASIC 1 5. A decision is taken at step 26 whether the boot key has been loaded and validation 
of the boot PROM 1 6 takes place in step 27 either directly or via step 28 if the boot key has to be entered. The process 
of validation in step 27 comprises the generation within the ASIC 15; of the expected digital signature using the 'boot' 
key. The generated digital signature is then compared to the actual digital signature from the boot PROM 16 and an 
Indication is generated in step 29 whether the boot PROM is valid. If not valid, the process in Figure 3 is stopped. 

so If the boot PROM 1 6 is validated, the process continues through the step 30 to execute the boot PROM and then 

begins in step 31 to operate on each of the plug-in cards 13. In the flow diagram of Figure 3, each card x (where x is 
the number of each card taken in turn) is checked by determining in step 32 if the corresponding card key has been 
entered In the ASIC 15 and validation proceeds in step 33 either directly if the key has been entered, or via the step 
34 if the key has still to be entered. Nfelidation of each plug-in card 1 3 is achieved by comparison of the digital signature 

ss generated for that card by the cryptographic engine 19 with the digital signature embedded in the card using the ap- 
propriate 'card X' key (where x is the number of each card taken in turn. An indicatton is generated in step 35 whether 
the card is valid. If the card is valid, the card initial code is executed in step 36. 

If there are succeeding cards to be validated, this is determined in step 37 and the validation of all the cards 
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continues until all have been validated. Following validation of the cards, the boot record is validated in step 38 and 
an indication provided in step 39 if the boot record is valid. The process of validation in step 38 is performed by gen- 
erating a digital signature for the operating system boot using the 'OS* key and comparing this against the digital 
signature stored in the digital signature store 20. If the boot record is valid, the boot record code is executed in step 

5 40 and the system is running. 

Referring now to Figure 4, the method of updating the keys will be described, to commence an operating system 
or card key update, from step 41 , a check is made whether the terminal is running in step 42. If not running, the system 
is powered up in step 43 and a check made in step 44 whether the system has failed. If yes, an update functkm key 
is pressed, a password for the selected key is entered and the new key is entered to arrive at the step 45 where the 

10 system starts normally. 

If at step 44 the terminal has not failed, the key update program is run in step 46 and the operator of the system 
selects which key to update in step 47. The password for the selected key is entered at step 48 , the new key is entered 
at step 49 and the system is powered down in step 50. The system component (either a card 1 3 or the BIOS) Is replaced 
at step 51 and the terminal powered up again at step 52. 

IS If there is a boot record failure as shown in step 53, an update function key is pressed at step 64 and the password 

for the operating system signature is entered at step 55. This results in the operating system digital signature being 
re-generated. The operating system operates normally at step 56, 

Once the operating system is started, the security is the responsibility of the operating system software. The se- 
curity ASIC 15 can then provide validation of digitally signed software. 

20 It will be apparent that the system described allows a trusted start up sequence that is required for successfully 

providing a complete secure system. It is envisaged that the keys could be stored in storage outside the security ASIC 
15. For example they could be encrypted under a master key which is heW within the security ASIC 15 which would 
make it Impossible to alter or replace the keys. 

25 

Clafnw 

1. A method of determining the authenticity of one or more system components of a data processing system which 
also includes a programmable central processor unit, memory, a security circuit having a cryptographic engine, 

30 and a cryptographs key store, characterized by the steps of entering one or more keys into the cryptographic key 
store, operating on the contents of the cryptographic key store by means of the cryptographic engine to generate 
a digital signature referenced to a component of the system to be authenticated, generating a digital signature 
from the component to be authenticated, and providing an indication of authenticity by comparing the digital sig- 
nature generated by the cryptographic engine with that generated from the component to be authenticated. 

3S 

2. A method as claimed in claim 1, including the further steps of updating a key in the cryptographic key store by 
selecting a key to be updated, entering a password for the selected key and entering the updated key 

3. A data processing system (10) including one or more components (1 3,16) to be checked for authenticity a pro- 
40 grammable central processing unit, (11 ) and a memory (12). characterized by a security circuit (1 5) having a cryp- 
tographic engine (19) and a cryptographic key store (18) for storing one or more cryptographic keys, the crypto- 
graphic engine being adapted to operate on the contents of the cryptographic key store to generate a digital sig- 
nature referenced to a component to be checked for authenticity, and means being provided to generate a digital 
signature from the component to be checked for authenticity and to provide an indication of authenticity by com- 

45 paring the digital signature generated by the cryptographic engine with that generated from the component to be 
authenticated. 

4. A system as claimed in claim 3, wherein a component to be checked for authenticity comprises boot firmware (16) 
for the system. 

so 

5. A system as claimed in claim 3 or 4. wherein a component to be checked for authenticity comprises an operating 
system. 

6. A system as claimed in claim 3. 4 or 5, wherein a component to be checked for authenticity comprises a plugnn 
ss card (13). 

7. A system as claimed in claim 3, 4. 5 or 6, wherein the security circuit (15) has means (18) for storing passwords 
to control the entry of cryptographic keys into the cryptographic key store. 
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8. A system as claimed In any one of claims 3 to 7, wherein the security circuit (18) comprises an integrated circuit. 

5 
10 
IS 
20 
2S 
30 
3S 
40 
4$ 
SO 



5 



EP 0 849 657 A1 



FIG. 1 



.10 



L 



12 



MEMORY 



11 



PROCESSOR 



15 




SECURITY 




BOOT 


ASIC 




FIRMWARE 



PROCESSOR DATA BUS 



CARD 
SLOTS 1-x 



10 



7 



PERMANENT 
STORAGE 



FIG. 2 



ASIC PACKAGE 



CRYPTOGRAPHIC 
KEY AND 
PASSWORD STORAGE 



-18 



CRYPTOGRAPHIC 
ENGINE 



19 



7 



L 



20 



DIGITAL 
SIGNATURE STORAGE 



ASIC CONTROL AND 
INTERFACE FIRMWARE 



.21 



ASIC I/O 



22 



6 



EP 0 849 657 A1 



POWER ON 



■23 



PROCESSOR STARTUP 



—24 



EXECUTE ASIC 
INITIAL CODE 



■ 25 




I 



28 



WAIT FOR 

BOOT 
KEY ENTRY 



VALIDATE PC BOOT PROM — 27 




NO 





r 




STOP 



EXECUTE BOOT PROM __3o 



FOR EACH 
PLUG-INCARDiX) 



• 31 




Ll 



34 



WAIT FOR 
CAROX 
KEY ENTRY 



FIG. 3 



VALIDATE 
CARDXPROM 



-33 










STOP 



EXECUTE CARDX 
INITIAL CODE 



— 36 






NO 


VALIDATE 
BOOT RECORD 







—38 










STOP 



EXECUTE BOOT 
RECORD CODE 



— 40 



SYSTEM 
RUNNING 



7 



EP 0 849 657 A1 



FIG. 4 
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